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(54) Method and apparatus for multiplatform instruction set architecture 



(57) A method and apparatus for providing a state- 
less multiplatform instruction set architecture (ISA) for 
use in a computer system having a processor and mem- 
ory storing a control program for implementing the inven- 
tion. The system is used to statelessly execute 
instructions authored to correspond to a variety of differ- 
ent ISA's on a unitary platform. The ISA of the invention 
uses a very long instruction word (VLIW) architecture 
with 64-bit instructions, of which several high-order bits 
are resen/ed for an ISA identifier tag. When the proces- 
sor receives an instruction for execution, it inspects the 
instruction to determine from the ISA identifier tag to 
which original, native ISA the instruction corresponds. If 
the con-esponding ISA is the native VLIW ISA for the 
processor, then the instruction is routed to the instruction 
dispatch unit of the processor, and thence to at least one 
furxrtional unit for execution. If the corresponding ISA is 
not the native VLIW ISA, then the instruction is routed to 
one of a plurality of dynamic decode units (DDU's), each 
DDU being controlled by a translation routine that trans- 
lates the instructions from a non-native ISA to the native 
VLIW ISA. The translated instructions are then sent to 
the instruction dispatch unit, and on to the appropriate 
functional unit{s). Any instruction that includes unused 
bits, such as 64-bit instructions with free higher-order 
bits, can accommodate the ISA identifier tag by simply 
using the unused bits. Instructions that do not include 
unused bits, such as 32-bit instructions for non-VLIW 
architectures (e.g. the ISA*s for SPARC. PowerPC or 
x86). are appended with additional bits to bring the total 
to 64 bits, several of which are reserved for the ISA tag. 
The number of bits reserved for the ISA tag determines 
the number of non-native ISA's that are recognized by 
the system; e.g.. three bits allows for the native ISA plus 
seven non-native ISA's to be recognized by the system. 
Incoming instaictions corresponding to a non-native ISA 



for which no dynamic decode unit is available can be exe- 
cuted by conventional software emulation. Entire pro- 
grams written for non-native ISA's (using, e.g.. 32-bit 
instructions) can be converted to the format for the native 
VLIW ISA t>y appending, at the instruction loading stage 
or in a separate process independent of execution, the 
additional bits necessary tx>th to fill out the instruction 
word lengths and to include the ISA identifier tag bits. 
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Description 

Background of the Invention 

This invention relates to a system, inplemented in s 
a computer processing unit, for executing instructions 
that comply with multiple, different instruction set archi- 
tectures (ISA's), and in particular to a processing unit that 
statelessly executes such instructions from different 
ISA's. 

A number of multiple- ISA platforms have been pro- 
posed which can accommodate different types of 
instructions by either binary translation or emulation. 
When binary translation is used, instructions that comply 
with a given instruction set architecture B (e.g. for x86 
processors) can be executed on a second instruction set 
architecture A (e.g. in conrpliance with the ISA for 
SPARC/IEEE Standard 1754 processors) by first being 
binarily translated into instructions that ISA A under- 
stands. They are then executed just as if they were orig- 
inally written for ISA A. 

This approach entails considerable overhead, in that 
the entire program for ISA B must first be binarily trans- 
lated before any of it can be run on the ISA-A processor 
This not only involves a delay before the user can proc- 
ess the instructions, but ties up the processing of instruc- 
tions, making the target processor unavailable until the 
binary translation is connplete. Furthermore, the user 
may need only a small portion of the code being trans- 
lated at a given time, making it highly inefficient to have 
to translate the entire code before accessing that portion. 

In addition, binary translation involves the copying 
of the original instructions, which may or may not be 
allowable by the user's license or by the law of the region 
where the user is executing the translation. Moreover, the 
translated instructions must be stored, so that the user 
is forced to save two copies of the code. If the translated 
copy is disposed of. then in order to use the code at a 
later time, it must again be translated to run on the ISA- 
A processor. 

Another approach to executing code written for ISA 
B on a system using ISA A is emulation, which may be 
either software emulation or hardware emulation. Soft- 
ware emulation involves inputting instructions that the 
processor for ISA A would not normally recognize, con- 
verting them Into equivalent ISA-A instructions, and exe- 
cuting the equivalent instructions in the A processor. TNs 
is done by setting the mode of the A processor to emulate 
ISA B, executing the ISA-B instructions, and then reset- 
ting the A processor back to mode A. i.e. for the native 
ISA. 

The mode change is accomplished by a special pro- 
gram that instructs the processor (or the software emu- 
lation program) to interpret a succeeding block of data 
(until resetting of the mode) as ISA-B instructions, e.g. 
telling a SPARC processor that the forthcoming block of 
data actually comprises x86 instructions. The SPARC 
processor then interprets each data word, one by one. 
as an instruction. When the block of data has been so 



executed as instructions, the rrxxJe-setting program 
resets the processor mode to the its native (e.g. SPARC) 
mode. 

While ISA-B instructions can successfully be exe- 
cuted this way. it is an inefficient and time-consuming 
approach, particularly for short sections of code where 
the overhead of mode changes becomes significant, and 
does not allow ISA-A and ISA-B instructions to be inter- 
mixed in a block of code; that is, the mode of the A proc- 
essor must be reset every time code for a different ISA 
is encountered, which involves considerable cycle-time 
overhead. This is especially so when, during the execu- 
tion of ISA-B code in processor A, an interrupt is received 
that requires the execution of a native ISA-A instruction. 
In this case, the ISA-A instruction must be trapped, inter- 
rupting the ISA-B code execution, and system checks 
whether it Is in the correct mode; and since it is not. the 
mode must be reset to mode A. The trapped instruction 
is then executed, and the system then resets back to 
mode Bto resume execution of the ISA-B code. This con- 
sumes an inordinate number of cyclea 

Hardware emulation can run faster than software 
emulation, using one or more dynamic decode units 
(which may be an integral part of the native processor, 
or may be in an add-on module). Conventional hardware 
emulation, like software emulation, also uses a mode- 
setting program, so that the processor knows what type 
of ISA is to be emulated by a given set of instructions, 
and sends the instructions to the appropriate dynamic 
decode unit. Though there is a speed-up in execution, 
the overhead inefficiencies of mode resetting, trapping 
and interrupting are the same as for software emulation. 

Another approach to accommodating multiple 
instruction set architectures involves incremental compi- 
lation, namely the compiling of portions of a program at 
a time. This has the advantage that an entire program 
needn't be compiled when only a piece of it is needed, 
and in a given setting may save considerable compilation 
time. It has the distinct disadvantage that it does not effi- 
ciently handle self-modifying code, since whenever the 
code is modified tt must be recompiled. 

In a loop, where the same instructions are executed 
repeatedly, either software or hardware emulation leads 
to recompiling the same block of code many times over, 
since the emulation procedure interprets each command 
anew when it is encountered. Incremental compilation 
can lead to the same repetition of compiling, when code 
self-modification occurs. This repetition of compilation is 
extremely wasteful of processor cycles. 

With the continued development of multiple instruc- 
tion set architectures in the market - - such as the 
SPARC. x86 and PowerPC ISA's and their respective 
operating systems (Solaris, DOS, MacOS) - it is becom- 
ing ever more important that users be capat>le of execut- 
ing applications developed for these differerrt instruction 
set architectures on a single hardware platform, in a 
manner that does not involve compilation of unneeded 
blocks of instructions, inefficient multiple connpilation of 
instructions, or the overhead associated with mode set- 
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ting. Particularfy useful would be a system that not only 
efficiently accommodates multple instruction set ardii- 
tedures. but can make use of the t>est of the many pro- 
grams written for different ISA's by allowing the 
intermixing of procedures with instructions from different 
instruction sets. 

Summary of the Invention 

The present invention allows the execution of 
instructions designed for multiple, normally incompatOsle 
instruction set architectures in a single new unified archi- 
tecture. In^ructions for a given 32-bit architecture are 
coupled to an additional 32-brt word containing a prede- 
termined block of bits constituting an ISA tag indicating 
the native ISA for the "visiting" code, i.e. the 32-bit 
instruction set architecture for which the code was writ- 
tea The entire 64-bit instruction stream is received by 
the "home" processor, which executes each instruction 
according to its ISA tag. 

The home processor thus utilizes a 64-bit irretruction 
set architecture, and in the foregoing manner can exe- 
cute instructions from any 32-bit architecture, in real time 
without recompilation or software emulation. In addition 
to reducing overhead relative to previous methods, this 
allows for a programmer to freely make use of subrou- 
tines, software modules and objects from multiple ISA's 
in a single application by simply tagging each imported 
block of code appropriately. The present invention is par- 
ticularly suited to a VLIW (very long instruction word) 
architecture, by which a true stateless multi-ISA system 
is achieved. 

Brief Pescription of the Drawings 

Rgure 1 is a fc>lock diagram of a computer system in 
which the present invention may be implemented. 

Figure 2 is a diagram indicating flow of 32-bit instruc- 
tions into a processor. 

Figure 3 is a diagram indicating flow of 64-brt instruc- 
tions of the cunrent invention into a processor. 

Figure 4 is a flow chart illustrating the preferred 
method of the invention, 

Rgure 5 is a block diagram depicting the dynamic 
decode units and functional units in a processor for 
Implementing the present invention. 

Rgure 6 is a flow chart illustrating a method for con- 
verting a block of conventional instructions into instruc- 
tions for execution according the present invention. 

Rgure 7 is a block diagram depicting instruction con- 
trol modules for a preferred embodiment of the invention. 

Description of the Preferred Enrtoodiments 

The system of tiie present invention is designed to 
be implemented in existing computer systems, such as 
the system 10 shown in Figure 1. including a central 
processing unit (CPU) 20 having a processor 30 and a 
memory 40. One or nrK>re storage media such as storage 



medium 50 will normally be used, e.g. disk or tape drives, 
CD-ROM. etc. I/O devices 60 are coupled to the CPU 20 
via an instruction loada^ 65, and may include such 
input/output peripherals as a keyboard, monitor, mouse, 

5 and so on. Thus, except as described below, conven- 
tional hardware may be used to inrplement the system 
of the present invention. 

The current invention is described herein in an 
emtxxiiment for statelessly executing instructions written 

10 for multiple, different instruction set architectures on a 
single platform, and in particular for executing 32-bit 
instructions on a 64-bit platform. It is equally applicable 
to tiie execution of any set of instructions, even different 
sets of different original sizes, on the single platform 

75 using instructions of greater length tiian the original, non- 
native instruction set architecture(s). The invention is 
best implemented in an operating system stored in the 
memory 40. namely in the form of control instructions, 
series of instruction, or program modules that include 

20 one or more control instructions, that are stored in the 
memory for carrying out the method steps descrikjed 
below. "Control modules" refers herein to any program, 
set of instructions, program routine, etc., that is config- 
ured to carry out one or more of the steps of the invention. 

25 (See Rgure 7.) 

Rgure 2 illusti-ates the flow of control ir^tructions, 
series of control instructions, or program nrKXlules each 
including one or more control instructions which are 70- 
78. in this case 32-bit instructions, into a processor 80. 

30 As described atxsve. there are a number of different ways 
of executing these instructions if they were not written for 
the native ISA of the processor 80. The dots above and 
below the instructions 70-78 indicate that there will typi- 
cally be many more instructions in a given program, rou- 

35 tine, or the like. 

Rgure 3 illustrates the flow of instructions 70A-78A. 
which are modified versions of instructions 70-78, into a 
processor 90 of the invention. Each instruction has been 
appended with an additional 32 bits, indicated in Rgure 

40 3 as bits 32-63. As an exemplary implementation, the top 
three bits (or other desired number of bits) may constitute 
a tag indicating the native ISA for each instruction. Three 
bits will identify eight different instruction set architec- 
tures, so the numt)er of bits for the tags T0-T8 (conre- 

45 spending to instructions 70A-78A. respectively) may be 
varied depending upon how many instruction set archi- 
tectures are to be accommodated. 

When an instruction is received by the processor 90, 
as at box 1 00 in Rgure 4 (and see Rgure 5), it is received 

50 into an instruction router 205, which routes directiy to an 
instruction dispatch unit 200 if it is for the native ISA (such 
as VLIW in the present example). If the incoming instruc- 
tion is an instruction relating to one of a number of pre- 
determined ISA's for which a DDU is available, it is routed 

55 by the instruction router 205 to the appropriate DDU for 
conversion into an instruction that can be recognized by 
the instruction dispatch unit 200. In either case, the 
instruction is then serrt on to an appropriate functional 
unit (280. etc.) for execution. The functional units (of 
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which there are three here for illustration, but may be an 
arbitrary number) Include the floating point unit, fetch 
unit, branch unit, arithmetic unit. etc. 

The correct routing of incoming instructions is 
accomplished as follows/ When an instruction is received s 
at the router 205. the corresponding tag is read to deter- 
mine the native ISA for the instaiction (see boxes 110 
and 120). The tags have preassigned meanings. For 
instance. 000 may refer to the native processor's ISA. for 
which no translation is necessary to be executed by the io 
processor 90. Table 1 gives an exemplary coding 
scheme: 



TABLE 1 



Ckxle 


Native Processor 


000 


VLIW 


001 


SPARC 


010 


PowerPC 


Oil 


x86 


100 


(Processor 5) 


101 


(Processor 6) 


110 


(Processor 7) 


111 


(Processor 8) 



When instruction 70A Is received by the processor 
90 (see Figures 3 and 5). it determines that the instruc- 
tion is. in this exarrple, a native VLIW instruction, i.e. was 
coded for the VLIW processor of the system. See box 35 
130 of Figure 4. Instruction 70A is accordingly routed by 
router 205 to the instruction dispatch unit 200 (see Figure 
5). as indicated at box 1 35 of Figure 4. and is sent to the 
appropriate functional unit 280. 290 or 300 for execution 
(box 160). 40 

The system then determines whether there are addi- 
tional instructions (box 170). and if there are. the next 
instruction is read (box 180). and the method returns to 
step 110. where that next instruction's tag is read. 

The next instruction at this point is instruction 71 A. 4S 
which is determined to be coded for the native VLIW 
processor, so It is executed in the same fashion as 
instruction 70A. This is also done for instruction 72Ai and 
then Instruction 73A is encountered, and its tag is read 
as above at step 110. so 

At step 120, it is deternrtined that the native ISA for 
Instruction 73 A is Sun Microsystems. Inc/s SPARC ISA. 
so the method proceeds to step 132, where it Is deter- 
mined whether the system includes a DDU for the iden- 
tified ISA. If the answer is positive, then the metiiod 55 
proceeds to step 140. If not. then the method proceeds 
to step 1 34. where it Is trapped and emulated In a soft- 
ware emulation step. 



In the present example, assuming an appropriate 
DDU is present in the system, the instruction is sent by 
tiie router 205 to the appropriate dynamic decode unit 
210-270. For one native and seven "non-native" proces- 
sors accommodated by a tiiree-bit tag. there will be a 
possible seven dynamic decode units (DDU's). If the 
Implementation has fewer than seven dynamic decode 
units, then the remaining ISA's may be trapped and emu- 
lated In software, thus allowing an effective trade-off 
between hardware execution speeds and econonrry of 
on-chip resources. This feature is further discussed 
below. 

The function of the DDU's is to convert the incoming 
Instructions into instructions tiiat are recognizable by the 
native processor 90. This Involves translating Instruc- 
tions one-to-one from the rx)n -native ISA to the native 
ISA (which can be done by a look-up tal>le); converting 
complex instructions Into several native ISA instructions 
(e.g.. complex x86 Insti-uctions may translate Into several 
VLIW Instructions); implementing condition codes of the 
non-native ISA as native-ISA condition codes: and so on. 
Those skilled in the art of developing applications for dif- 
ferent ISA's will be able to straightfonwardly implement 
these DDU's. 

The functions and steps carried out in the present 
Invention may. as discussed above, be convenientiy 
Implemented as discrete, interacting instruction control 
modules stored in the memory 40 (See Rgure 7). The 
functions of the modules shown in Figure 7 will be clear 
from the discussion below. Several modules may be 
combined into a single module, and otiier nx)dules may 
be Included as necessary for any discretely identifiable 
functions of the invention. 

Thus, at box 140 of Figure 4 it is determined that 
Instruction 73 A should be sent to the appropriate DDU. 
such as DDU1 (Item 21 0 in Figure 5). The sending of the 
instruction to DDU1 and Interpretation therein are repre- 
sented in box 150 of Figure 4. DDU1 which translates 
tfie instruction into one or more VLIW instructions, and 
passes it (or tiiem) on to the instruction dispatch unit 200 
(Figure 5). as Indicated at box 135 in Figure 4. The dis- 
patch unit 200 passes the instruction(5) on as necessary 
to the appropriate functional unit for execution (box 160). 

At box 170 it is found that tiiere is an additional 
instruction in the instruction sti-eam. so the method pro- 
ceeds to step 180. where instruction 74A is read. Its tag 
is read at box 1 10. and again it is found to be a SPARC 
instruction, i.e. it is determined from its tag "001" (see 
Figure 3) that it should be sent to DDUI . 

The next two instructions 75A and 76A are native 
VLIW Instructions (having codes "000"), and are accord- 
ingly passed by instruction router 205 to the instruction 
dispatch unit 200. Instruction 77A is found to pertain to 
an x86 processor (see Table 1 above), by virtue of Its tag 
"1 1 0". and tfius is sent by the router 205 to the appropri- 
ate DDU, e.g. DDU3 (Item 230 in Figure 5). 

Instruction 78A is found again to be a native VLIW 
command, so is routed directly to the dispatch unit 200 
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(see Figure 5). Succeeding instructions are each treated 
in the same fashion. 

It can be seen that the system provides a truly state- 
less manner of dynamically (in real time) executing 
instructions originating from code authored for an arbi- s 
trarily large number of instruction set architectures. This 
allows a programmer to write applications in a very flex- 
ible manner, using routines, modules and objects from a 
wide variety of ISA's in a single application, on a line-by- 
line basis if desired. There is no processing penalty at io 
execution time for doing so, and there is no overhead 
involved in either precompilation or mode setting. 

The instruction router 205. instruction dispatch unit 
200, DDU's210-270 and functional units 280-300 in Rg- 
ure 5 would typically be an integral part of the processor is 
90. However, any of these may be designed to be a sep- 
arate element, depending on the user's selected system 
architecture. In general, these may be refereed to herein 
as hardware modules 'coupled to" the processor, 
whether they are an integral part of the processor or, in 20 
any particular case, a module separate from the main 
processor. As discussed below, the router 205 and units 
200-300 all are controlled by instructions or instruction 
modules stored in memory, that are used to receive, 
inspect, route, convert and otherwise manipulate incom- 25 
ing instructions as necessary. 

The DDU's shown in Rgure 5 may be integral to the 
processor, as shown, or may be plug-in nrxKiules that can 
be added on later. Thus, the system of the invention nnay 
first be configured to accommodate a given number of 30 
ISA's, and later instruction set architecfajres may be 
accommodated by adding on modules and reconfiguring 
the native system's ISA accordingly 

As alluded to above, the system of the invention may 
be combined with conventional systems for maximum 35 
flexibility For instance, if it is desired to execute code for 
a given ISA for which no DDU is availafcHe. tiien for that 
code conventional software emulation may still be used 
- - as represented by boxes 132-134 in Figure 4. where 
conventional software emulation is carried out for 40 
instructions for which no DDU is available to the system. 
The ir|3ut code may accordingly include blocks of instruc- 
tions for a given ISA that is to t>e software-emulated, 
while the remainder of the instructions may be as 
described above, appended witii tags to indicate their 45 
native ISA's. Likewise, binary translation or hardware 
emulation could be used in conjunction with instructions 
that are otherwise configured to take advantage of the 
present invention, though the latter is less likely since, if 
a DDU is availat)le for a given ISA, it is a straightforward so 
matter to use it In a innplementation of the invention, as 
described at>ove. 

Figure 6 illustrates a method for converting a block 
of instructions for a given ISA into instructions conform- 
ing to the structure depicted in Figure 3, suitatrfe for exe- ss 
cution on the system of the invention. This method is 
carried out by instructions stored in the memory of the 
compute" system and executed by means of the loader 
65 shown in Figure 1 . 



The non-native instructions are received at step 31 0 
(see Rgure 6) into the loader 65. which is provided with 
information as to which ISA the instructions were 
authored for. To each instruction is apperxJed the 32-bit 
structure (bits 32-63) shown at the left of the instruction 
stream shewn in Rgure 3 (step 320), including the appro- 
priate tag in each case for the non-native ISA (step 330). 
The instructions are thereby modified and converted into 
64-bit instructions, and at step 340 are stored in their 
modified form. The instructions may now be executed in 
the above-described manner. 

When such blocks of non-native code are converted 
and executed, correct addressing is automatically 
accommodated by the system of the invention. In Rgure 
2, instruction 70 may be at address "n", instruction 71 at 
address n-i-4 (assuming 8-byte words), and so on. After 
conversion, the instructions have the structure shown in 
Rgure 3, and now converted instruction 70 A has (VLIW) 
address 'n', but instruction 71 A has address mS instead 
of thA, instruction 72A has address n+1 6 instead of n+8, 
and so on. This could present a problem, especially 
when relative addressing is used, so the system of the 
invention is provided with a mechanism to hide the addi- 
tional address space occupied by the 64-bit instruction 
set, while translating instructions from the 32-bit instruc- 
tion set This can be accommodated by allowing each 
address to identify two bytes instead of one byte. This 
wouki be visible to the native ISA, but the visiting ISA 
woukj not be aware that there were more bytes of storage 
identified by each address, thus hiding the high-order 32 
bits of the 64-bit instruction field from it 

The original, non-native code, once modified as 
described relative to Rgure 6. does not need any addi- 
tional modification to execute correctiy. For a given 
addressing scheme, it is a straightforward matter to gen- 
erate the necessary code for converting the addresses 
appropriately for the system of the invention: for instance, 
in the present example, tiie previous addresses having 
values (n + Z), where Z is an offset of 0, 4, 8, 1 2 etc., are 
converted into addresses having values (n + 2*Z). I.e. 
the offsets are doubled to 0. 8, 1 6. 24 and so on. 

It will be appreciated that the aforementioned prob- 
lem of executing self-modifying instructions on a non- 
native platfbnm is solved by tiie present invention, since 
all instructions are executed almost as native instructions 
are, by first being converted in real time by the DDUs. 
Thus, any code modifications are automatically accom- 
nxxJated, with no recompilation or other overhead 
encountered by binary translation or emulation. 

The additional space taken up by these 64-bit 
instructions will increase the amount of memory band- 
widtii and space taken up in the instruction cache. How- 
ever, this is not likely to be a problem, since the VLIW 
processor needs a much larger than 32-bit instruction 
anyway to provide access to a larger register file and 
instruction encodings, and the terrqx)ral and spatial 
locality exhibited by instructions will keep the vast major- 
ity of instruction references to the on-chip cache instead 
of using up additional bandwidth to memory. Thus, there 
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should not be any appreciable increase in cache misses 
due to the increased instruction size of the present inven- 
tion, while considerable cycles are saved by the direct 
multi-ISA system. 

Claims 

1 . A system for executing first instructions and second 
instructions in a connputer system including a proc- 
essor, a memory coupled to said processor and stor- 
ing a plurality of control modules comprising 
program instructions for manipulating said first and 
second instructions, the first and second instruc- 
tions being configured according to first and second 
predetermined instruction set architectures (ISA's), 
respectively, where the first ISA is a native ISA for 
said processor and the second ISA is a non-native 
ISA for the processor, the system including: 

an instnjction router coupled to the processor 
for receiving said first and second instructions: 

an instruction dispatch unit coupled to said 
instruction router for receiving at least said first 
instructions: 

at least one dynamic decode unit coupled to 
said instruction router for receiving said second 
instructions; 

an ISA tag coupled to each instruction in said 
first and second instructions, identifying the corre- 
sponding ISA for that instruction; 

a tag reading control module for reading each 
said ISA tag of said first and second sets of instruc- 
tions: 

a tag identification control module for deter- 
mining the ISA corresponding to each said ISA tag; 

a first routing control module for routing at 
least some said instructions having an ISA tag cor- 
responding to the processor's native ISA to said 
instruction dispatch unit; 

a second routing control module for routing 
at least some said instructions having an ISA tag 
corresponding to said predetermined non-native 
ISA to said dynamic decode unit: and 

a translation control nxxiule for translating 
instructions received at said dynamic decode unit 
into modified instructions corresponding to said 
native ISA for said processor. 

2. The system of claim 1 , further including a thud rout- 
ing control module for passing said modified instruc- 
tions to said instruction dispatch unit. 

3. The system of claim 1 , further including: 

at least one functional unit coupled to said 
instruction dispatch unit for receiving instructions 
therefrom and for executing said instructions; and 

a fourth routing control module for passing 
instructions received at said instruction dispatch unit 
to said functional unit. 



4. The system of claim 1 . further including: 

an instruction loader coupled to said instruc- 
tion router; 

a loader control module for converting at least 
5 some said second instructions into a format includ- 

ing said ISA tag. 

5. The system of daim 4. wherein said loader control 
module further includes instructions for appending 

10 at least one additional bit to each of a plurality of said 
second instructions, said additional bit comprising 
said ISA tag. 

6. A method for executing insb^uctions on a computer 
IS system having a processor, a memory coupled to 

said processor, at least one functional unit coupled 
to said processor, at least one dynamic decode unit 
coupled to said processor, and control program 
modules stored in said memory for manipulating 

20 said instructions, the instructions corresponding to 
a first predetermined instruction set architecture 
(ISA) that is non-native to said processor, the 
metiiod including the steps of: 

receiving at least one said instruction at said 

25 processor; 

inspecting said insti-uction to determine 
whether it corres|3onds to a native ISA for said proc- 
essor, and if so then passing said instruction to said 
functional unit for execution; 

30 if said inspected insfuction relates to said 

first predetermined non-native ISA. then translating 
said inspected instruction into a modified instruction 
corresponding to said native ISA; and 

passing said modified instruction to said 

35 functional unit for execution. 

7. The method of claim 6, further including, before said 
receiving step, the step of: 

converting at least one said instruction into a 
40 format corresponding to said native ISA to identify 
said instruction as corresponding to said non-native 
ISA. 

8. The method of claim 7, wherein: 

45 the converting step includes the step of 

appending at least one additional bit to at least one 
said instruction, said at least one additional bit com- 
prising an ISA identifier tag. 

so 9. The method of claim 8. wherein said inspecting step 
includes the steps of: 

reading said ISA identifier tag; and 
determining to which ISA said identifier tag 
corresponds. 

55 

10. The method of claim 7, including, after the inspecting 
step, the additional step of: 

if said inspected instruction corresponds to a 
second predetermined ISA that is also non-native to 
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said processor, then emulating said inspected 
instruction. 



patch unit to at least one saki functional unit for exe- 
cution. 



1 1 . The method oi daim 1 0, wherein said enruilating step 
conprises soft>Arare emulation. 

12. A system for executing instructions in a computer 
system including a processor, a memory coupled to 
said processor and storing a plurality of control mod- 
ules comprising program instructions for manipulat- 
ing said instructions, said instructions being 
configured according to at least one of first and sec- 
ond predetermined instruction set architectures 
(ISA's), where the first ISA is a native ISA for said 
processor and the second ISA is a predetermined 
non-native ISA for the processor, the system includ- 
ing: 

an ir^truction router coupled to the processor 
for receiving said instructions; 

an instruction dispatch unit coupled to said 
instruction router for receiving at least a first sut)set 
of said instructions; 

at least one dynamic decode unit coupled to 
said instruction loader for receiving at least a second 
subset of said instructions; 

an ISA identifier corresponding to each of a 
plurality of said instructions, identifying a native ISA 
for each of said plurality of instructions; 

an ISA identification control module for deter- 
mining for each of said plurality of instructions the 
native ISA for that instruction; 

a routing control nrxxfule for routing at least 
some of said first subset of instructions to said 
instruction dispatch unit and for routing at least some 
of said second subset of instructions to said dynamic 
decode unit: and 

a dynamic decode unit control module for 
converting instructions received at said dynamic 
decode unit into modified instructions correspond- 
ing to said native ISA for said processor. 

13. The system of claim 12. wherein: 

said first sut)set of instructions correspond to 
a format relating to said native ISA for said proces- 
sor; and 

said second subset of instructions corre- 
spond to a format relating to said predetermined 
non-native ISA. 

14. The system of claim 12, wherein said dynamic 
decode unit control module includes control instruc- 
tions for routing said nxxiified instructions to said 
instruction dispatch unit. 

15. The system of claim 12, further including: 

a plurality of functional units coupled to said 
instruction dispatch unit; and 

an instruction dispatch unit control module for 
routing instructions received at said instruction dis- 
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16. The system of daim 12. wherein said ISA identifier 
comprises a tag induding at least one bit appended 
to each of said plurality of said instructions. 

17. The system of daim 12, further irrcluding: 

an instruction loader coupled to said proces- 
sor for receiving said instructions for input to and 
execution by said processor; 

an instruction conversion control module for 
converting each of a plurality of said instructions to 
a format corresponding to said native ISA for said 
processor. 

18. The system of claim 17, wherein said instruction 
conversion module indudes conversion instructions 
for appending to each of said plurality of said instruc- 
tions a field containing an ISA identifier tag. 

19. The system of daim 12, further including: 

an instruction emulation conti^ol nrxxiule for 
emulating a second predetermined ISA that is non- 
native to said processor. 

20. The system of claim 18, wherein said instruction 
emulation corrtrol module comprises instructions for 
software emulation of commands of said second 
predetermined ISA. 
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